
 <!DOCTYPE HTML>
<html >
<head>
  <meta charset="UTF-8">
  
    <title>第十二周周报 | B3434lockchain</title>
    <meta name="viewport" content="width=device-width, initial-scale=1,user-scalable=no">
    
    <meta name="author" content="b3434lockchain">
    

    
    <meta name="description" content="第三次周报关于《以太坊技术详解与实战》的学习分析（P59-112）（周报内容为从书上内容的总结，纯手打，可能会比较精简） 1） 部署以太坊联盟链 2） 智能合约与以太坊虚拟机 3） 总结 1） 部署以太坊联盟链1.1.传世区块文件的编写创世区块中包含config，config中的内容是区块链相关的基本配置参数。chainId为区块链编号，是其中最重要的部分。alloc是以太坊的账户信息，可以留空待">
<meta name="keywords" content="周报,苏思捷">
<meta property="og:type" content="article">
<meta property="og:title" content="第十二周周报">
<meta property="og:url" content="http://b3434lockchain.gitee.io/2018/11/24/susijie/susijie5/index.html">
<meta property="og:site_name" content="B3434lockchain">
<meta property="og:description" content="第三次周报关于《以太坊技术详解与实战》的学习分析（P59-112）（周报内容为从书上内容的总结，纯手打，可能会比较精简） 1） 部署以太坊联盟链 2） 智能合约与以太坊虚拟机 3） 总结 1） 部署以太坊联盟链1.1.传世区块文件的编写创世区块中包含config，config中的内容是区块链相关的基本配置参数。chainId为区块链编号，是其中最重要的部分。alloc是以太坊的账户信息，可以留空待">
<meta property="og:locale" content="default">
<meta property="og:updated_time" content="2018-11-26T11:11:34.000Z">
<meta name="twitter:card" content="summary">
<meta name="twitter:title" content="第十二周周报">
<meta name="twitter:description" content="第三次周报关于《以太坊技术详解与实战》的学习分析（P59-112）（周报内容为从书上内容的总结，纯手打，可能会比较精简） 1） 部署以太坊联盟链 2） 智能合约与以太坊虚拟机 3） 总结 1） 部署以太坊联盟链1.1.传世区块文件的编写创世区块中包含config，config中的内容是区块链相关的基本配置参数。chainId为区块链编号，是其中最重要的部分。alloc是以太坊的账户信息，可以留空待">

    
    <link rel="alternative" href="/atom.xml" title="B3434lockchain" type="application/atom+xml">
    
    
    <link rel="icon" href="/img/favicon.ico">
    
    
    <link rel="apple-touch-icon" href="/img/jacman.jpg">
    <link rel="apple-touch-icon-precomposed" href="/img/jacman.jpg">
    
    <link rel="stylesheet" href="/css/style.css">
</head>

  <body>
    <header>
      
<div>
		
			<div id="imglogo">
				<a href="/"><img src="/img/logo.png" alt="B3434lockchain" title="B3434lockchain"/></a>
			</div>
			
			<div id="textlogo">
				<h1 class="site-name"><a href="/" title="B3434lockchain">B3434lockchain</a></h1>
				<h2 class="blog-motto"></h2>
			</div>
			<div class="navbar"><a class="navbutton navmobile" href="#" title="Menu">
			</a></div>
			<nav class="animated">
				<ul>
					<ul>
					 
						<li><a href="/">Home</a></li>
					
						<li><a href="/archives">Archives</a></li>
					
						<li><a href="/about">About</a></li>
					
					<li>
 					
						<form class="search" action="https://www.baidu.com" target="_blank">
							<label>Search</label>
						<input name="s" type="hidden" value=  ><input type="text" name="q" size="30" placeholder="Search"><br>
						</form>
					
					</li>
				</ul>
			</nav>			
</div>
    </header>
    <div id="container">
      <div id="main" class="post" itemscope itemprop="blogPost">
  
	<article itemprop="articleBody"> 
		<header class="article-info clearfix">
  <h1 itemprop="name">
    
      <a href="/2018/11/24/susijie/susijie5/" title="第十二周周报" itemprop="url">第十二周周报</a>
  </h1>
  <p class="article-author">By
       
		<a href="/about" title="b3434lockchain" target="_blank" itemprop="author">b3434lockchain</a>
		
  <p class="article-time">
    <time datetime="2018-11-24T13:15:00.000Z" itemprop="datePublished"> Published 2018-11-24</time>
    
  </p>
</header>
	<div class="article-content">
		
		<div id="toc" class="toc-article">
			<strong class="toc-title">Contents</strong>
		
			<ol class="toc"><li class="toc-item toc-level-1"><a class="toc-link" href="#第三次周报"><span class="toc-number">1.</span> <span class="toc-text">第三次周报</span></a><ol class="toc-child"><li class="toc-item toc-level-2"><a class="toc-link" href="#1）-部署以太坊联盟链"><span class="toc-number">1.1.</span> <span class="toc-text">1） 部署以太坊联盟链</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#1-1-传世区块文件的编写"><span class="toc-number">1.1.1.</span> <span class="toc-text">1.1.传世区块文件的编写</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#1-2-账户的创建与挖矿"><span class="toc-number">1.1.2.</span> <span class="toc-text">1.2.账户的创建与挖矿</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#2-智能合约与以太坊虚拟机"><span class="toc-number">1.2.</span> <span class="toc-text">2.智能合约与以太坊虚拟机</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#（1）智能合约"><span class="toc-number">1.2.1.</span> <span class="toc-text">（1）智能合约</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#（2）Solidity语言"><span class="toc-number">1.2.2.</span> <span class="toc-text">（2）Solidity语言</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#3-总结"><span class="toc-number">1.3.</span> <span class="toc-text">3.总结</span></a></li></ol></li></ol>
		
		</div>
		
		<h1 id="第三次周报"><a href="#第三次周报" class="headerlink" title="第三次周报"></a>第三次周报</h1><p>关于《以太坊技术详解与实战》的学习分析（P59-112）（周报内容为从书上内容的总结，纯手打，可能会比较精简）</p>
<p>1） 部署以太坊联盟链</p>
<p>2） 智能合约与以太坊虚拟机</p>
<p>3） 总结</p>
<h2 id="1）-部署以太坊联盟链"><a href="#1）-部署以太坊联盟链" class="headerlink" title="1） 部署以太坊联盟链"></a>1） 部署以太坊联盟链</h2><h3 id="1-1-传世区块文件的编写"><a href="#1-1-传世区块文件的编写" class="headerlink" title="1.1.传世区块文件的编写"></a>1.1.传世区块文件的编写</h3><p>创世区块中包含config，config中的内容是区块链相关的基本配置参数。chainId为区块链编号，是其中最重要的部分。alloc是以太坊的账户信息，可以留空待以后创建。coinbase是挖矿收益账户，difficulty是挖矿难度，最开始最好设置较低数值不然耗费时间很大（血的教训..），而gaslimit为每个区块消耗的gas限制，其他参数可以留空，然后就可以进行初始化配置</p>
<h3 id="1-2-账户的创建与挖矿"><a href="#1-2-账户的创建与挖矿" class="headerlink" title="1.2.账户的创建与挖矿"></a>1.2.账户的创建与挖矿</h3><p>通过person.newAccount（””)创建新账户，其中自己填写密码，创建后返回账户地址，如我的第一个账户地址为：”0xbfcc53c457f34d74ba25cda8b5cbeaabda067113”</p>
<p>通过eth.getBalance(eth.accounts[0])查询我账户的余额，返回0.此时启动挖矿程序进行挖矿，miner.start()并控制在挖出第一个区块时调用miner.stop()停止。此时花了一分钟，账户余额增加。</p>
<p>通过对账户解锁后进行转账操作，第一次操作时发现账户余额并未改变，然后去查找资料发现应当进行挖矿，把转账信息写到链上，转账才有效，所以再次通过miner.start进行挖矿，可以发现账户余额更改。</p>
<p>通过getBlock可以查看块信息，输入交易的地址值可以看交易的详细信息如从谁到谁金额数目大小。体现了区块链的透明的特点。</p>
<h2 id="2-智能合约与以太坊虚拟机"><a href="#2-智能合约与以太坊虚拟机" class="headerlink" title="2.智能合约与以太坊虚拟机"></a>2.智能合约与以太坊虚拟机</h2><h3 id="（1）智能合约"><a href="#（1）智能合约" class="headerlink" title="（1）智能合约"></a>（1）智能合约</h3><p>智能合约其实就是一个代理人。智能合约由合约代码控制，智能合约的账户存储了保存合约的状态。智能合约在以太坊每个节点中在各自的EVM中执行代码，会产生大量平行计算（因为相同东西相同结果计算的次数太多了），不过这也能保证更高安全性。不过多个节点的计算导致的一个问题就是不能产生随机数，因为随机数的生成可能会在不同节点的值不一样，智能合约有自己的账户，可以卖家与买家的一手交钱一手交货。</p>
<p>在以太坊额存储中，有栈、账户存储和内存，账户存储和内存相当于计算机的硬盘，和计算机工作原理一样，通常在合约执行过程中实用内存（耗费的资源小），然后在结果写入账户存储（更持久，不易更改和丢失）。</p>
<p>以太坊有指令集和消息调用，消息调用最大好处就是能方便智能合约开发者编写更加丰富的合约，能调用他人现成的合约节省很多资源。为了防止其代码陷入恶性循环，以太坊使用Gas限制机制。</p>
<h3 id="（2）Solidity语言"><a href="#（2）Solidity语言" class="headerlink" title="（2）Solidity语言"></a>（2）Solidity语言</h3><p>Solidity语音和自己以前学的语音有点类似，有很多共通性，所以看起来比较好理解，下面介绍这个语言一些特色：</p>
<p>1.<strong>结构</strong>  他和c++中的class很像，在一个合约中可以声明成员包括状态变量、函数、函数修改器、事件等。同时也和类一样可以继承，声明一个状态变量为uint XXX，声明函数 function XX（），还有函数修改器和事件。</p>
<p>2.<strong>变量类型——值类型</strong> 变量类型的值有布尔类型、整数、枚举还有我觉得比较特殊的地址类型，地质类型可以通过显式类型转换将合约转换为地址类型，地址类型有一丢丢的函数如.balance查看余额，.transfer转账，该函数与send的区别是转账失败时抛出异常。</p>
<p>3.<strong>变量类型——引用类型</strong> 有数组、结构体、映射。数组中有平常数组的一些函数如length返回长度，应该注意的是bytes和string，在转换时会有UTF-8编码计算长度和单个字符计算长度的差别。<br>4.<strong>变量类型——类型转换与运算符与类型推断</strong> 其中较为需要注意的时delete函数不是释放内存，而是将其变量赋值为0.如delete app和app=0是等价的。var声明的变量将拥有第一个赋值变量的类型。</p>
<p>5.<strong>单位与控制语句</strong> 其中默认货币单位（不加后缀）为wei，在区块中，有诸如block.coinbase查询矿工地址和.difficulty查询挖矿难度（前面一节内容对这些函数都跑了一遍）。而控制语句与C++无差别。</p>
<p>6.<strong>最重要的——函数</strong> 函数包含自己对合约的诸多操作，我觉得是其最重要的一部分。函数可以有多个参数和返回值。函数调用分为内部调用（对合约内函数调用），和外部调用（调用其他合约），函数外部调用方法是申请一个实例对象进行调用，构造函数中不能通过this调用函数，因为此时还未完成。函数调用会抛出异常，有四种情况。与众多语音一样，对于函数有很多前缀修饰，在该语音中有1.external（表明外部函数），2.public（公开函数，合约内外都可访问），3.internal（内部函数），4.私有函数（只有合约内部才能访问）。需要注意的是，可见性只限制其他合约访问权限，我们还是都能看到的。其中，fallback函数是以前没接触过的，当一个合约无法匹配如何函数名或者仅仅用于转账交易时，就会被自动执行，可以进行重构。但值得注意的是，它的Gas只有2300，所以我们在重构其函数时不能超过，否则在验证签名等过程需要更多的Gas。而其中函数修改器能一定程度修改函数，常用于验证条件。</p>
<h2 id="3-总结"><a href="#3-总结" class="headerlink" title="3.总结"></a>3.总结</h2><p>通过自己部署区块链，感受到了一种“自己当上帝”的感觉，产生了浓厚的兴趣以致对书里每个函数都实现和研究了一遍，了解了转账挖矿等过程。在后面章节了解了智能合约的构成和运行原理，对以前自己了解的迷恋猫的程序加深了理解，也逐渐了解到其底层的一些工作原理。</p>
  
	</div>
		<footer class="article-footer clearfix">
<div class="article-catetags">


  <div class="article-tags">
  
  <span></span> <a href="/tags/周报/">周报</a><a href="/tags/苏思捷/">苏思捷</a>
  </div>

</div>



	<div class="article-share" id="share">
	
	  <div data-url="http://b3434lockchain.gitee.io/2018/11/24/susijie/susijie5/" data-title="第十二周周报 | B3434lockchain" data-tsina="" class="share clearfix">
	  </div>
	
	</div>


</footer>

   	       
	</article>
	
<nav class="article-nav clearfix">
 
 <div class="prev" >
 <a href="/2018/11/25/lujiahao/lujiahao5/" title="编写链码程序并测试">
  <strong>上一篇：</strong><br/>
  <span>
  编写链码程序并测试</span>
</a>
</div>


<div class="next">
<a href="/2018/11/18/tanjunxi/tanjunxi5/"  title="谭俊熙_Fabric-sdk-java尝试编写自己的调用逻辑">
 <strong>下一篇：</strong><br/> 
 <span>谭俊熙_Fabric-sdk-java尝试编写自己的调用逻辑
</span>
</a>
</div>

</nav>

	



</div>  
      <div class="openaside"><a class="navbutton" href="#" title="Show Sidebar"></a></div>

  <div id="toc" class="toc-aside">
  <strong class="toc-title">Contents</strong>
 
 <ol class="toc"><li class="toc-item toc-level-1"><a class="toc-link" href="#第三次周报"><span class="toc-number">1.</span> <span class="toc-text">第三次周报</span></a><ol class="toc-child"><li class="toc-item toc-level-2"><a class="toc-link" href="#1）-部署以太坊联盟链"><span class="toc-number">1.1.</span> <span class="toc-text">1） 部署以太坊联盟链</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#1-1-传世区块文件的编写"><span class="toc-number">1.1.1.</span> <span class="toc-text">1.1.传世区块文件的编写</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#1-2-账户的创建与挖矿"><span class="toc-number">1.1.2.</span> <span class="toc-text">1.2.账户的创建与挖矿</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#2-智能合约与以太坊虚拟机"><span class="toc-number">1.2.</span> <span class="toc-text">2.智能合约与以太坊虚拟机</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#（1）智能合约"><span class="toc-number">1.2.1.</span> <span class="toc-text">（1）智能合约</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#（2）Solidity语言"><span class="toc-number">1.2.2.</span> <span class="toc-text">（2）Solidity语言</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#3-总结"><span class="toc-number">1.3.</span> <span class="toc-text">3.总结</span></a></li></ol></li></ol>
 
  </div>

<div id="asidepart">
<div class="closeaside"><a class="closebutton" href="#" title="Hide Sidebar"></a></div>
<aside class="clearfix">

  

  
<div class="tagslist">
	<p class="asidetitle">Tags</p>
		<ul class="clearfix">
		
			
				<li><a href="/tags/周报/" title="周报">周报<sup>23</sup></a></li>
			
		
			
				<li><a href="/tags/谭俊熙/" title="谭俊熙">谭俊熙<sup>11</sup></a></li>
			
		
			
				<li><a href="/tags/苏思捷/" title="苏思捷">苏思捷<sup>5</sup></a></li>
			
		
			
				<li><a href="/tags/学习报告/" title="学习报告">学习报告<sup>5</sup></a></li>
			
		
			
				<li><a href="/tags/卢家豪/" title="卢家豪">卢家豪<sup>5</sup></a></li>
			
		
			
				<li><a href="/tags/报告/" title="报告">报告<sup>5</sup></a></li>
			
		
			
				<li><a href="/tags/苏佳鑫/" title="苏佳鑫">苏佳鑫<sup>4</sup></a></li>
			
		
			
				<li><a href="/tags/冯华文/" title="冯华文">冯华文<sup>4</sup></a></li>
			
		
			
				<li><a href="/tags/周报反馈/" title="周报反馈">周报反馈<sup>2</sup></a></li>
			
		
			
				<li><a href="/tags/吴朝捷/" title="吴朝捷">吴朝捷<sup>2</sup></a></li>
			
		
			
				<li><a href="/tags/黎宁/" title="黎宁">黎宁<sup>1</sup></a></li>
			
		
			
				<li><a href="/tags/笔记/" title="笔记">笔记<sup>1</sup></a></li>
			
		
		</ul>
</div>


</aside>
</div>
    </div>
    <footer><div id="footer" >
	
	
	<div class="social-font" class="clearfix">
		
		
		
		
		
		
		
		
		
		
	</div>
			
		

		<p class="copyright">
		
		</p>
</div>
</footer>
    <script src="/js/jquery-2.0.3.min.js"></script>
<script src="/js/jquery.imagesloaded.min.js"></script>
<script src="/js/gallery.js"></script>
<script src="/js/jquery.qrcode-0.12.0.min.js"></script>

<script type="text/javascript">
$(document).ready(function(){ 
  $('.navbar').click(function(){
    $('header nav').toggleClass('shownav');
  });
  var myWidth = 0;
  function getSize(){
    if( typeof( window.innerWidth ) == 'number' ) {
      myWidth = window.innerWidth;
    } else if( document.documentElement && document.documentElement.clientWidth) {
      myWidth = document.documentElement.clientWidth;
    };
  };
  var m = $('#main'),
      a = $('#asidepart'),
      c = $('.closeaside'),
      o = $('.openaside');
  c.click(function(){
    a.addClass('fadeOut').css('display', 'none');
    o.css('display', 'block').addClass('fadeIn');
    m.addClass('moveMain');
  });
  o.click(function(){
    o.css('display', 'none').removeClass('beforeFadeIn');
    a.css('display', 'block').removeClass('fadeOut').addClass('fadeIn');      
    m.removeClass('moveMain');
  });
  $(window).scroll(function(){
    o.css("top",Math.max(80,260-$(this).scrollTop()));
  });
  
  $(window).resize(function(){
    getSize(); 
    if (myWidth >= 1024) {
      $('header nav').removeClass('shownav');
    }else{
      m.removeClass('moveMain');
      a.css('display', 'block').removeClass('fadeOut');
      o.css('display', 'none');
      
      $('#toc.toc-aside').css('display', 'none');
        
    }
  });
});
</script>

<script type="text/javascript">
$(document).ready(function(){ 
  var ai = $('.article-content>iframe'),
      ae = $('.article-content>embed'),
      t  = $('#toc'),
      ta = $('#toc.toc-aside'),
      o  = $('.openaside'),
      c  = $('.closeaside');
  if(ai.length>0){
    ai.wrap('<div class="video-container" />');
  };
  if(ae.length>0){
   ae.wrap('<div class="video-container" />');
  };
  c.click(function(){
    ta.css('display', 'block').addClass('fadeIn');
  });
  o.click(function(){
    ta.css('display', 'none');
  });
  $(window).scroll(function(){
    ta.css("top",Math.max(140,320-$(this).scrollTop()));
  });
});
</script>


<script type="text/javascript">
$(document).ready(function(){ 
  var $this = $('.share'),
      url = $this.attr('data-url'),
      encodedUrl = encodeURIComponent(url),
      title = $this.attr('data-title'),
      tsina = $this.attr('data-tsina'),
      description = $this.attr('description');
  var html = [
  '<div class="hoverqrcode clearfix"></div>',
  '<a class="overlay" id="qrcode"></a>',
  '<a href="https://www.facebook.com/sharer.php?u=' + encodedUrl + '" class="article-share-facebook" target="_blank" title="Facebook"></a>',
  '<a href="https://twitter.com/intent/tweet?url=' + encodedUrl + '" class="article-share-twitter" target="_blank" title="Twitter"></a>',
  '<a href="#qrcode" class="article-share-qrcode" title="微信"></a>',
  '<a href="http://widget.renren.com/dialog/share?resourceUrl=' + encodedUrl + '&srcUrl=' + encodedUrl + '&title=' + title +'" class="article-share-renren" target="_blank" title="人人"></a>',
  '<a href="http://service.weibo.com/share/share.php?title='+title+'&url='+encodedUrl +'&ralateUid='+ tsina +'&searchPic=true&style=number' +'" class="article-share-weibo" target="_blank" title="微博"></a>',
  '<span title="Share to"></span>'
  ].join('');
  $this.append(html);

  $('.hoverqrcode').hide();

  var myWidth = 0;
  function updatehoverqrcode(){
    if( typeof( window.innerWidth ) == 'number' ) {
      myWidth = window.innerWidth;
    } else if( document.documentElement && document.documentElement.clientWidth) {
      myWidth = document.documentElement.clientWidth;
    };
    var qrsize = myWidth > 1024 ? 200:100;
    var options = {render: 'image', size: qrsize, fill: '#2ca6cb', text: url, radius: 0.5, quiet: 1};
    var p = $('.article-share-qrcode').position();
    $('.hoverqrcode').empty().css('width', qrsize).css('height', qrsize)
                          .css('left', p.left-qrsize/2+20).css('top', p.top-qrsize-10)
                          .qrcode(options);
  };
  $(window).resize(function(){
    $('.hoverqrcode').hide();
  });
  $('.article-share-qrcode').click(function(){
    updatehoverqrcode();
    $('.hoverqrcode').toggle();
  });
  $('.article-share-qrcode').hover(function(){}, function(){
      $('.hoverqrcode').hide();
  });
});   
</script>











<link rel="stylesheet" href="/fancybox/jquery.fancybox.css" media="screen" type="text/css">
<script src="/fancybox/jquery.fancybox.pack.js"></script>
<script type="text/javascript">
$(document).ready(function(){ 
  $('.article-content').each(function(i){
    $(this).find('img').each(function(){
      if ($(this).parent().hasClass('fancybox')) return;
      var alt = this.alt;
      if (alt) $(this).after('<span class="caption">' + alt + '</span>');
      $(this).wrap('<a href="' + this.src + '" title="' + alt + '" class="fancybox"></a>');
    });
    $(this).find('.fancybox').each(function(){
      $(this).attr('rel', 'article' + i);
    });
  });
  if($.fancybox){
    $('.fancybox').fancybox();
  }
}); 
</script>



<!-- Analytics Begin -->





<!-- Analytics End -->

<!-- Totop Begin -->

	<div id="totop">
	<a title="Back to Top"><img src="/img/scrollup.png"/></a>
	</div>
	<script src="/js/totop.js"></script>

<!-- Totop End -->

<!-- MathJax Begin -->
<!-- mathjax config similar to math.stackexchange -->


<!-- MathJax End -->

<!-- Tiny_search Begin -->

<!-- Tiny_search End -->

  </body>
</html>
